

# 8202A DYNAMIC RAM CONTROLLER

- Provides All Signals Necessary to Control 2104A, 2117, or 2118 Dynamic Memories
- Directly Addresses and Drives Up to 128K Bytes Without External Drivers
- Provides Address Multiplexing and Strobes
- Provides a Refresh Timer and a Refresh Counter
- Refresh Cycles May be Internally or Externally Requested

- Provides Transparent Refresh Capability
- Fully Compatible with Intel® 8080A, 8085A, iAPX 88, and iAPX 86 Family Microprocessors
- Decodes CPU Status for Advanced Read Capability
- Provides System Acknowledge and Transfer Acknowledge Signals
- External Clock Capability

The Intel® 8202A is a Dynamic Ram System Controller designed to provide all signals necessary to use 2104A, 2117, or 2118 Dynamic RAMs in microcomputer systems. The 8202A provides multiplexed addresses and address strobes, as well as refresh/access arbitration. Refresh cycles can be started internally or externally.



Figure 1. 8202A Block Diagram

Figure 2. Pin Configuration



Table 1. Pin Descriptions

|                                                                                                                                   |                                      |                                       | <del> </del>                                                                                                                                                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol                                                                                                                            | Pin<br>No.                           | Туре                                  | Name and Function                                                                                                                                                                                                                                                                       |
| AL <sub>0</sub> AL <sub>1</sub> AL <sub>2</sub> AL <sub>3</sub> AL <sub>4</sub> AL <sub>5</sub> AL <sub>6</sub> OP <sub>3</sub>   | 6<br>8<br>10<br>12<br>14<br>16<br>18 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Address Low: CPU address in-<br>puts used to generate memory<br>row address.<br>AL <sub>6</sub> /OP <sub>3</sub> used to select 4K<br>RAM mode.                                                                                                                                         |
| AH <sub>0</sub><br>AH <sub>1</sub><br>AH <sub>2</sub><br>AH <sub>3</sub><br>AH <sub>4</sub><br>AH <sub>5</sub><br>AH <sub>6</sub> | 5<br>4<br>3<br>2<br>1<br>39<br>38    |                                       | Address High: CPU address in-<br>puts used to generate memory<br>column address.                                                                                                                                                                                                        |
| BO<br>B <sub>1</sub> /OP <sub>1</sub>                                                                                             | 24<br>25                             | 1                                     | Bank Select Inputs: Used to gate the appropriate RAS <sub>0</sub> -RAS <sub>3</sub> output for a memory cycle. B <sub>1</sub> /OP <sub>1</sub> option used to select the Advanced Read Mode.                                                                                            |
| PCS                                                                                                                               | 33                                   | 1                                     | Protected Chip Select: Used to enable the memory read and write inputs. Once a cycle is started, it will not abort even if PCS goes inactive before cycle completion.                                                                                                                   |
| WR                                                                                                                                | 31                                   | ī                                     | Memory Write Request.                                                                                                                                                                                                                                                                   |
| RD/S1                                                                                                                             | 32                                   | 1                                     | Memory Read Request: \$1 function used in Advanced Read mode selected by OP <sub>1</sub> (pin 25).                                                                                                                                                                                      |
| REFRQ/<br>ALE                                                                                                                     | 34                                   | ı                                     | External Refresh Request: ALE function used in Advanced Read mode, selected by OP <sub>1</sub> (pin 25).                                                                                                                                                                                |
| OUT <sub>0</sub> OUT <sub>1</sub> OUT <sub>2</sub> OUT <sub>3</sub> OUT <sub>4</sub> OUT <sub>5</sub> OUT <sub>6</sub>            | 7<br>9<br>11<br>13<br>15<br>17       | 0 0 0 0 0 0                           | Output of the Multiplexer: These outputs are designed to drive the addresses of the Dynamic RAM array. For 4K RAM operation, OUT <sub>6</sub> is designed to drive the 2104A CS input. (Note that the OUT <sub>0-6</sub> pins do not require inverters or drivers for proper operation. |
| WE                                                                                                                                | 28                                   | 0                                     | Write Enable: Drives the Write Enable inputs of the Dynamic RAM array.                                                                                                                                                                                                                  |
| CAS                                                                                                                               | 27                                   | 0                                     | Column Address Strobe: This output is used to latch the Column Address into the Dynamic RAM array.                                                                                                                                                                                      |

| Symbol                                                                       | Pin<br>No.           | Туре | Name and Function                                                                                                                                                                                                                                                                        |
|------------------------------------------------------------------------------|----------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RAS <sub>0</sub><br>RAS <sub>1</sub><br>RAS <sub>2</sub><br>RAS <sub>3</sub> | 21<br>22<br>23<br>26 | 0000 | Row Address Strobe: Used to latch the Row Address into the bank of dynamic RAMs, selected by the 8202A Bank Select pins (B <sub>0</sub> , B <sub>1</sub> /OP <sub>1</sub> ).                                                                                                             |
| XACK                                                                         | 29                   | o    | Transfer Acknowledge: This output is a strobe indicating valid data during a read cycle or data written during a write cycle.  XACK can be used to latch valid data from the RAM array.                                                                                                  |
| SACK                                                                         | 30                   | O    | System Acknowledge: This output indicates the beginning of a memory access cycle. It can be used as an advanced transfer acknowledge to eliminate wait states. (Note: If a memory access request is made during a refresh cycle, SACK is delayed until XACK in the memory access cycle). |
| OP <sub>2</sub><br>CLK                                                       | 36<br>37             | 1    | Clock Inputs: These inputs are used to control the frequency of the 8202A. CLK is a TTL input for an external clock and OP <sub>2</sub> must be strapped to +12V.                                                                                                                        |
| N.C.                                                                         | 35                   |      | Reserved for future use.                                                                                                                                                                                                                                                                 |
| VCC                                                                          | 40                   |      | Power Supply: +5V.                                                                                                                                                                                                                                                                       |
| GND                                                                          | 20                   |      | Ground.                                                                                                                                                                                                                                                                                  |



Figure 3. External Clock Operation

# **Functional Description**

The 8202A provides a complete dynamic RAM controller for microprocessor systems as well as expansion memory

8-15 AFN-00203D



boards. All of the necessary control signals are provided for 2104A, 2117, and 2118 dynamic RAM's.

All 8202A timing is generated from a single reference clock. This clock is provided via an external oscillator. All output signal transitions are synchronous with respect to this clock reference, except for the CPU handshake signals SACK and XACK (trailing edge).

CPU memory requests normally use the  $\overline{RD}$  and  $\overline{WR}$  inputs. The advanced READ mode allows ALE and S1 to be used in place of the  $\overline{RD}$  input.

Failsafe refresh is provided via an internal refresh timer which generates internal refresh requests. Refresh requests can also be generated via the REFRQ input.

An on-chip synchronizer/arbiter prevents memory and refresh requests from affecting a cycle in progress. The READ, WRITE, and external REFRESH requests may be asynchronous to the 8202A clock; on-chip logic will synchronize the requests, and the arbiter will decide if the requests should be delayed, pending completion of a cycle in progress.

## **Option Selection**

The 8202A has two hardware strapping options which can be selected by connecting the appropriate pin to a 12 volt power source through a current-limiting resistor. See "DC Characteristics" for more detail.

When OP<sub>1</sub> is selected, pin 32 changes from a RD input to an S1 input, and pin 34 changes from a REFREQ input to an ALE input. See "Refresh Cycles" and "Read Cycles" for more detail.

When OP<sub>3</sub> is selected, the 8202A will change its internal refresh timer from 128-row refresh (2117, 2118) to 64-row refresh (2104A).

#### Refresh Timer

The refresh timer is used to monitor the time since the last refresh cycle occurred. When the appropriate amount of time has elapsed, the refresh timer will request a refresh cycle. External refresh requests will reset the refresh timer.

#### **Refresh Counter**

The refresh counter is used to sequentially refresh all of the memory's rows. The counter is incremented after every refresh cycle.

## Address Multiplexer

The address multiplexer takes the address inputs and the refresh counter outputs, and gates them onto the address outputs at the appropriate time. The address outputs, in conjunction with the RAS<sub>0</sub>-RAS<sub>3</sub> and CAS outputs, determine the address used by the dynamic RAMs for read, write, and refresh cycles. During the first part of a read or write cycle, AL<sub>0</sub>-AL<sub>6</sub> are gated to OUT<sub>0</sub>-OUT<sub>6</sub>, then AH<sub>0</sub>-AH<sub>6</sub> are gated to the address outputs.

During a refresh cycle, the refresh counter is gated onto the address outputs. All refresh cycles are RAS-only refresh (CAS inactive, RAS<sub>0</sub>-RAS<sub>3</sub> active).

To minimize buffer delay, the information on the address outputs is inverted from that on the address inputs.

OUT<sub>0</sub>-OUT<sub>6</sub> do not need inverters or buffers unless additional drive is required beyond the 32 chip load.

#### Synchronizer/Arbiter

The 8202A has two inputs,  $\overline{\text{RD}}$  (pin 32) and  $\overline{\text{WR}}$  (pin 31), which allow an external CPU to request a memory read or write cycle, respectively. An additional input, REFRQ/ALE (pin 34), allows refresh requests to be requested external to the 8202A.

All three of these inputs may be asynchronous with respect to the 8202A's clock. The arbiter will resolve conflicts between refresh and memory requests, for both pending cycles and cycles in progress. Read and write requests will be given priority over refresh requests.

#### **System Operation**

The 8202A is always in one of the following states:

- a) IDLE
- b) TEST Cycle
- c) REFRESH Cycle
- d) READ Cycle
- e) WRITE Cycle

The 8202A is normally in the IDLE state. Whenever one of the other cycles is requested, the 8202A will leave the IDLE state to perform the desired cycle. If no other cycles are pending, the 8202A will return to the IDLE state.

## **Test Cycle**

The TEST Cycle is used to check operation of several 8202A internal functions. TEST cycles are requested by activating the RD and WR inputs, independent of PCS. The

| Description | Pin # | Normal Function   | +12 Volt Function  |
|-------------|-------|-------------------|--------------------|
| B1/OP1      | 25    | Bank (RAS) Select | Advanced-Read Mode |
| AL6/OP3     | 18    | Address Input     | 64-ROW Refresh     |

Figure 4. 8202A Option Selection



TEST Cycle will reset the refresh address counter and perform a WRITE Cycle. The TEST Cycle should not be used in normal system operation, since it would affect the dynamic RAM refresh.

## Refresh Cycles

The 8202A has two ways of providing dynamic RAM refresh:

- 1) Internal (failsafe) refresh
- 2) External (hidden) refresh

Both types of 8202A refresh cycles activate all of the  $\overline{RAS}$  outputs, while  $\overline{CAS}$ ,  $\overline{WE}$ ,  $\overline{SACK}$ , and  $\overline{XACK}$  remain inactive.

Internal refresh is generated by the on-chip refresh timer. The timer uses the 8202A clock to ensure that refresh of all rows of the dynamic RAM occurs every 2 milliseconds. If REFRQ is inactive, the refresh timer will request a refresh cycle every 10-16 microseconds.

External refresh is requested via the REFRQ input (pin 34). External refresh control is not available when the Advanced-Read mode is selected. External refresh requests are latched, then synchronized to the 8202A clock.

The arbiter will allow the refresh request to start a refresh cycle only if the 8202A is not in the middle of a cycle.

If a memory request and a refresh request reach the arbiter at the same time, the 8202A will honor the refresh request first. However, the external refresh synchronization takes longer than the memory request synchronization, so, relative to the 8202A input signals, a simultaneous memory request and external refresh request will result in the memory request being honored first. This 8202A characteristic can be used to "hide" refresh cycles during system operation. A circuit similar to Figure 5 can be used to decode the CPU's instruction fetch status to generate an external refresh request. The refresh request is latched while the 8202A performs the instruction fetch; the refresh cycle will start immediately after the memory cycle is completed, even if the RD input has not gone inactive. If the CPU's instruction decode time is long enough, the 8202A can complete the refresh cycle before the next memory request is generated.

After each refresh cycle, the 8202A increments the refresh counter, reloads the refresh timer, and clears the external refresh latch. If the external refresh request is held active, the latch will be set again, and another refresh cycle will be generated. However, if a memory request is pending, it will be honored before the second refresh request. This feature prevents refresh from locking out memory request.



Figure 5. Hidden Refresh

Certain system configurations require complete external refresh requests. If external refresh is requested faster than the minimum internal refresh timer (tREF), then, in effect, all refresh cycles will be caused by the external refresh request, and the internal refresh timer will never generate a refresh request.

## **Read Cycles**

The 8202A can accept two different types of memory Read requests:

- 1) Normal Read, via the RD input
- 2) Advanced Read, using the S1 and ALE inputs

The user can select the desired Read request configuration via the B1/OP1 hardware strapping option on pin 25.

|              | Normal Read             | Advanced Read   |
|--------------|-------------------------|-----------------|
| Pin 25       | B1 input                | +12 Volt Option |
| Pin 32       | RD input                | S1 input        |
| Pin 34       | REFRQ input             | ALE input       |
| # RAM banks  | 4 (RAS <sub>0-3</sub> ) | 2 (RAS 2-3)     |
| Ext. Refresh | Yes                     | No              |

Figure 6. 8202A Read Options

Normal Reads are requested by activating the RD input, and keeping it active until the 8202A responds with an XACK pulse. The RD input can go inactive as soon as the command hold time (tCHS) is met.

Advanced Read cycles are requested by pulsing ALE while S1 is active; if S1 is inactive (low) ALE is ignored. Advanced Read timing is similiar to Normal Read timing, except the falling edge of ALE is used as the cycle start reference.

If a Read cycle is requested while a refresh cycle is in progress, then the 8202A will set the internal delayed-SACK latch. When the Read cycle is eventually started, the 8202A will delay the active SACK transition until XACK goes active, as shown in the AC timing diagrams. This delay was designed to compensate for the CPU's READY



setup and hold times. The delayed-SACK latch is cleared after every READ cycle.

Based on system requirements, either SACK or XACK can be used to generate the CPU READY signal. XACK will normally be used; if the CPU can tolerate an advanced READY, then SACK can be used, but only if the CPU can tolerate the amount of advance provided by SACK. If SACK arrives too early to provide the appropriate number of WAIT states, then either XACK or a delayed form of SACK should be used.

## **Write Cycles**

Write cycles are similiar to Normal Read cycles, except for the WE output. WE is held inactive for Read cycles, but goes active for Write cycles. All 8202A Write cycles are "early-write" cycles; WE goes active before CAS goes active by an amount of time sufficient to keep the dynamic RAM output buffers turned off.

## **General System Considerations**

All memory requests (Normal Reads, Advanced Reads, Writes) are qualified by the PCS input. PCS should be stable, either active or inactive, prior to the leading edge of RD, WR, or ALE. Systems which use battery backup should pullup PCS to prevent erroneous memory requests, and should also pullup WR to keep the 8202A out of its test mode.

In order to minimize propagation delay, the 8202A uses an inverting address multiplexer without latches. The system must provide adequate address setup and hold times to guarantee  $\overline{\text{RAS}}$  and  $\overline{\text{CAS}}$  setup and hold times for the RAM. The 8202A tad AC parameter should be used for this system calculation.

The B0-B1 inputs are similiar to the address inputs in that they are not latched. B0 and B1 should not be changed during a memory cycle, since they directly control which RAS output is activated.

The 8202A uses a two-stage synchronizer for the memory request inputs (RD, WR, ALE), and a separate two stage synchronizer for the external refresh input (REFRQ). As with any synchronizer, there is always a finite probability of metastable states inducing system errors. The 8202A synchronizer was designed to have a system error rate less than 1 memory cycle every three years based on the full operating range of the 8202A.

A microprocessor system is concerned with the time data is valid after  $\overline{\text{RD}}$  goes low. See Figure 7. In order to calculate memory read access times, the dynamic RAM's A.C. specifications must be examined, especially the RAS-access time (trac) and the CAS-access time (trac). Most configurations will be CAS-access limited; i.e., the data from the RAM will be stable  $\text{tc}_{\text{CC},\text{max}}$  (8202A) + trace (RAM) after a memory read cycle is started. Be sure to add any delays (due to buffers, data latches, etc.) to calculate the overall read access time.

Since the 8202A normally performs "early-write" cycles, the data must be stable at the RAM data inputs by the time CAS goes active, including the RAM's data setup time. If the system does not normally guarantee sufficient write data setup, you must either delay the WR input signal or delay the 8202A WE output.

Delaying the  $\overline{WR}$  input will delay all 8202A timing, including the READY handshake signals,  $\overline{SACK}$  and  $\overline{XACK}$ , which may increase the number of WAIT states generated by the CPU.

If the WE output is externally delayed beyond the CAS active transition, then the RAM will use the falling edge of WE to strobe the write data into the RAM. This WE transition should not occur too late during the CAS active transition, or else the WE to CAS requirements of the RAM will not be met.



Figure 7. Read Access Time





Figure 8. Typical 8088 System

8-19 AFN-00203D





Figure 9. 8086/128K Byte System

AFN-00203D